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ADAPTIVE SEARCH METHOD IN FEATURE VECTOR SPACE 

This application is a complete application filed under 35 U S.C §11 1(a) and claims, 
pursuant to 35 U.S.C. §119 (e)(1). benefit of the filing date of Provisional Application Serial 
No. 60/248.012 filed November 14, 2000 pursuant to 35 U.S.C. §11 1(b). The Provisional 
Application Serial No. 60/248,012 is incorporated herein by reference. Additionally, this 
application claims priority from Korean Application No. 00-79181 filed December 20. 2000, 
which is also incorporated herein by reference. 

BACKGROUND OF THE INVENTION 

1 . Field of the Invention 

The present invention generally relates to a method of searching a feature vector 
space for a feature vector that has similar features to a query vector. More specifically, the 
method of the present invention provides a method for efficiently searching a vector space 
indexed based on an approximation for a feature vector having features similar to a query 
vector according to a varying distance measurement. 

2. Description of the Related Art 

In a multimedia database related to a multimedia application, the contents are 
typically represented by feature vectors. Similarities among objects are determined by a 
distance measurement defined by feature distances between the query vector and feature 
vectors in a feature vector space. 



To provide further precise retrievals, a distance measurement may be iteratively 
performed using collected information such as user feedback. However, a conventional 
search method does not consider how to iteratively perform a distance measurement 
according to varying factors m a large database. In particular, a conventional indexing 
method m a feature vector space has not addressed how to quickly perform a search m an 
environment where a distance measurement is changing, such as on-line retrieval. Thus, 
there still remains a need for accelerating a search in an environment where a distance 
measurement is varying. 

SUMMARY OF THE INVENTION 

To solve the above problems, it is an objective of the present invention to provide a 
method for quickly and iteratively searching an approximated feature vector space for a 
feature vector similar to a query vector according to varying measurement conditions. 

Accordingly, to achieve the above objective, the present invention provides a method 
for adaptively searching a feature vector space which includes the steps of (a) performing a 
similarity measurement on a given query vector within a feature vector space, and (b) 
applying search conditions limited by the result of the similarity measurement obtained in 
step (a) and performing a changed similarity measurement on the given query vector. 

Preferably, step (b) includes the steps of (b-1) obtaining candidate approximation 
regions by performing approximation level filtering according to a distance measurement 
limited by the result of the similar measurement obtained m step (a), and (b-2) performing 
data level filtering on the obtained candidate approximation regions 

Preferably, step (a) includes the steps of (a- 1 ) obtaining a predetermined number of 
nearest candidate approximation regions by measuring the distance^ between the query vector 
and approximation regions, and (a-2) obtaining K nearest neighbor feature vectors by 



measuring the distance between each of all feature vectors in the obtained candidate 
approximation regions and the query vector, where K is a positive integer. 

Preferably, step (b-1) includes the steps of (b-I-1) calculating K'-th shortest distance 
for the K nearest neighbor feature vectors obtained according to the previous distance 

5 measurement according to a changed distance measurement, where K' is a positive integer, 
and setting the calculated distance as r u ,+ i- and (b-1-2) calculating K'-th smallest lower bound 
limit for the predetermined number of candidate approximation regions based on the previous 
distance measurement according to the changed distance measurement and set as 0 u t _i- 
Preferably, step (b-1) also includes the following steps of: (b-l-3a) measuring a 

10 distance L,(W t+1 ) between the lower bound limit of an approximation region and a query 

vector for a new distance measurement, wherein N is a positive integer denoting the number 
of objects in the feature vector space and 1 is a variable ranging from 1 to N; (b-1 -4) 
comparing the distance L,(W t+1 ) obtained in the step (b-l-3a) with a minimum value mm ((J), 
r u t+! , 0 u t+ i) of K-th smallest upper bound limit <p, r u t+ i, and 0 u t+] : and (b-1 -5) if the distance 

15 L,(W t+l ) is less than or equal to the minimum value min (0, r u 1+ i< <?Vi), setting the 

corresponding approximation region as a candidate approximation region: and (b-1 -6) if the 
distance L,(W 1+1 ) is greater than the minimum value mm r u ,+ i- <? l 't+i)- excluding the 
corresponding approximation region. 

Additionally, step (b-1) further includes (b-l-3b) measuring a distance U,(W t+1 ) 

20 between the upper bound limit of an approximation region and the quer\ vector for the new 
distance measurement, assuming that N is a positive integer denoting the number of objects 
in the feature vector space and i is a variable ranging from 1 to N. and (b-L-7) updating the K- 
th smallest upper bound limit 0 based on the distance U,(W K |). 



Furthermore, steps (b-1-1) - (b-1-6) are repeated until the approximation level 
filtering is performed on N approximation regions where N is a positive integer denoting the 
number of objects m a database. 

Preferably, step (b-2) further includes the steps of (b-2-1) performing a distance 
5 measurement between each of all feature vectors m the candidate approximation regions and 
the query vector, and (b-2-2) determining K' nearest neighbor feature vectors as retrieved 
vectors depending on the result of the distance measurements performed m the step (b-2-1). 

BRIEF DESCRIPTION OF THE DRAWINGS 

The above objective and advantages of the present invention will become more 
10 apparent by describing in detail preferred embodiments thereof with reference to the attached 
drawings in which: 

FIGS. 1A and IB are flowcharts showing main steps of a method for adaptively 
searching a feature vector space according to an embodiment of the present invention; and 
FIG. 2 is a pseudo code list for explaining approximation level filtering. 



15 DETAILED DESCRIPTION OF THE INVENTION 

The main steps of an adaptive search method according to an embodiment of the 
present invention will now be described with reference to FIGS. 1A and IB. A database m 
which multimedia contents are stored is represented as a feature vector space. In this 
embodiment, the feature vector space is approximated with a plurality of hypercubes. 
20 Furthermore, assuming that M is a positive integer denoting the dimensionality of feature 
vectors used to describe an image/video object, and N is a positive integer denoting the 
number of objects in the database, feature vector F and feature vector Q of a query object Q 



4 



are defined as F = [F,i, F l2 F im ] and Q = [q,), q im , respectively. Here, the database 

is represented as a feature vector space and the feature vector Q of a query object Q is 
hereinafter called a query vector. 

First, a predetermined number of nearest candidate hypercubes are obtained by 
5 measuring the distance between a query vector and each of hypercubes (step 102). Then, K 
of nearest neighbor feature vectors are obtained by measuring the distance between the query 
vector and each feature vector m the predetermined number of candidate hypercubes obtained 
in the step 102, where K is a positive integer (step 104). The distance between the query 
vector and each of the feature vectors is measured by calculating weighted Euclidean 
10 distance. The weighted Euclidean distance is calculated by Equation (1): 



d(W.,F,,Q) = (Q-F) T W,(Q-F) ...(1) 

where W t is a full symmetric function matrix at iteration t and updated at every iteration. 

Then, for example, the user selects a plurality of multimedia contents similar to those 

that he or she desires to find among calculated multimedia contents and attempts a search 
15 again. Thus, feedback for changed search conditions can be provided from the user, which is 

called relevance feedback. According to the present invention, features for which feedback is 

provided from the user are reflected in a distance measurement for the next seaich, thereby 

changing distance measurement conditions. 

According to the present invention, approximation level filtering is performed using 
20 information from previous iteration t. W t , Ci(W ( ). and Ri denote a distance measurement 

function used in the previous iteration t. approximation regions that passed the previous 

iteration t or hypercubes in this embodiment, and vectors retrieved using W t , respectively. 



FIG. 2 shows a pseudo code list for explaining the step of approximation level 
filtering. The approximation level filtering is performed using the information from the 
previous iteration t. Referring to FIG. 2, according to the pseudo codes, during the 
approximation level filtering, the K'-th shortest distance is calculated for the K nearest 
neighbor feature vectors based on the previous distance measurement according to the 
changed distance measurement where K' is a positive integer, and the calculated distance is 
set as rVi (step 106). Furthermore, K'-th smallest lower bound limit is calculated for the 
predetermined number of candidate hypercubes obtained according to the previous distance 
measurement according to the changed distance measurement and set as <p u l+ \ (step 108). 

Then, the distance Li(W t+1 ) between each of the lower bound limits of hypercubes in 
the feature vector space and a query vector are measured according to the changed new 
distance measurement. Additionally, the distance U,(W !+1 ) between each of the upper bound 
limits of the hypercubes m the feature vector space and the query vector are measured 
according to the changed new distance measurement as well (step 1 10). The measurements 
are done assuming that N is the number of objects or approximation regions in the 
approximated feature vector space or a positive integer denoting the number of hypercubes. 
Additionally, 1 is assumed to be a variable ranging from 1 to N. Furthermore, the K'-th 
smallest upper bound limit (J) is calculated (step 1 12). 

Next, the distance L,(W t+1 ) between the lower bound limit of l-th hypercube in the 
corresponding vector space and the query \ector is compared with a minimum value mm (0, 
r u l+ i, 0Vi) of the K'-th smallest upper bound limit § calculated in the step 1 12, r u 1+1 , and (£>Vi 
(step 1 14). If the distance L,(W t+1 ) is less than or equal to the minimum value mm (o, r u I+1 , 
0 u t+ i). a relevant hypercube is set as a candidate hypercube (step 1 16) and if not, the relevant 
hypercube is excluded (step 1 18). 



Referring to pseudo code 202 in FIG. 2, it is determined whether or not the distance 
L,(W 1+ |) between the lower bound limit of i-th hypercube in the corresponding vector space 
and the query vector is smaller than all of the K'-th smallest upper bound limits (J), r u t+1 , and 
0 u t+ i. If so, the relevant hypercube P, is selected as a candidate hypercube as shown pseudo 
5 code 204. Referring to pseudo code 206. if requirements shown in the pseudo code 202 are 
satisfied, the relevant hypercube P, is selected as a candidate hypercube, and the upper bound 
limit § is updated referring to the distance U,(W t+ i) (step 120). 

Next, assuming that N is a positive integer denoting the number of objects in the 
database or hypercubes, it is determined whether i reaches N (step 124). If i does not reach 
10 N, the steps 114 - 124 are repeated until the approximation level filtering is performed on N 
hypercubes. 

According to the method described above, for a hypercube to be set as a candidate 
hypercube, the hypercube must meet new requirements determined from the previous 
distance measurement information such as the pseudo code 202. Thus, requirements foi- 
ls selecting candidate hypercubes are further limited, thereby reducing the number of selected 
candidate hypercubes. 

Data level filtering is then performed. During the filtering, a distance measurement 
between each of all feature vectors m the candidate hypercubes and the query vector is 
performed (step 126) to determine K" nearest neighbor vectors as found feature vectors 
20 depending on the result of the distance measurements performed m the step 126, thereby 

completing a search (step 128). In this case, the number of candidate hypercubes is reduced, 
which reduces the computational complexity m measuring the distance between each feature 
vectors m the candidate cubes and the query vector. Thus, the search speed can be improved 
when searching for a feature vector having features similar to a query vector. 
25 Additionally, if new approximation regions are included, the database can be updated faster. 



Although the preferred embodiments of this invention has been described with 
reference to the example that the feature vector space is partitioned into hypercubes and 
approximated, the invention is also applicable to feature vector spaces indexed by other 
known index structures such as R-tree, R* tree, SR-tree and X-tree. It will be understood by 
5 those skilled in the art that various changes in form and details may be made therein without 
departing from the spirit and scope of the invention as defined by the appended claims. 

The search method according to the present invention can be written as a program 
executed on a personal or server computer. The program codes and code segments 
constructing the program can be easily inferred by computer programmers in the industry. 
10 Furthermore, the program can be stored in a computer-readable recording medium. The 

recording medium includes a magnetic recording medium, an optical recording medium, and 
a radio medium. 

According to the present invention, the number of approximation regions is reduced 
during a varying distance measurement, which improves a search speed. 



